# DRAM Configuration Guide

TCCxxxx-Android-ALL-V1.00E-DRAM Configuration Guide

Dec 15, 2010.



#### **DISCLAIMER**

All information and data contained in this material are without any commitment, are not to be considered as an offer for conclusion of a contract, nor shall they be construed as to create any liability. Any new issue of this material invalidates previous issues. Product availability and delivery are exclusively subject to our respective order confirmation form; the same applies to orders based on development samples delivered. By this publication, Telechips, Inc. does not assume responsibility for patent infringements or other rights of third parties that may result from its use.

Further, Telechips, Inc. reserves the right to revise this publication and to make changes to its content, at any time, without obligation to notify any person or entity of such revisions or changes.

No part of this publication may be reproduced, photocopied, stored on a retrieval system, or transmitted without the express written consent of Telechips, Inc.

This product is designed for general purpose, and accordingly customer be responsible for all or any of intellectual property licenses required for actual application. Telechips, Inc. does not provide any indemnification for any intellectual properties owned by third party.

Telechips, Inc. can not ensure that this application is the proper and sufficient one for any other purposes but the one explicitly expressed herein. Telechips, Inc. is not responsible for any special, indirect, incidental or consequential damage or loss whatsoever resulting from the use of this application for other purposes.

#### COPYRIGHT STATEMENT

Copyright in the material provided by Telechips, Inc. is owned by Telechips unless otherwise noted.

For reproduction or use of Telechips' copyright material, permission should be sought from Telechips. That permission, if given, will be subject to conditions that Telechips' name should be included and interest in the material should be acknowledged when the material is reproduced or quoted, either in whole or in part. You must not copy, adapt, publish, distribute or commercialize any contents contained in the material in any manner without the written permission of Telechips. Trade marks used in Telechips' copyright material are the property of Telechips.

### **Important Notice**

This product may include technology owned by Microsoft Corporation and in this case it cannot be used or distributed without a license from Microsoft Licensing, GP.

#### For customers who use licensed Codec ICs and/or licensed codec firmware of mp3:

"Supply of this product does not convey a license nor imply any right to distribute content created with this product in revenue-generating broadcast systems (terrestrial. Satellite, cable and/or other distribution channels), streaming applications(via internet, intranets and/or other networks), other content distribution systems(pay-audio or audio-on-demand applications and the like) or on physical media(compact discs, digital versatile discs, semiconductor chips, hard drives, memory cards and the like). An independent license for such use is required. For details, please visit http://mp3licensing.com".

#### For customers who use other firmware of mp3:

"Supply of this product does not convey a license under the relevant intellectual property of Thomson and/or Fraunhofer Gesellschaft nor imply any right to use this product in any finished end user or ready-to-use final product. An independent license for such use is required. For details, please visit http://mp3licensing.com".

#### For customers who use Digital Wave DRA solution:

"Supply of this implementation of DRA technology does not convey a license nor imply any right to this implementation in any finished end-user or ready-to-use terminal product. An independent license for such use is required."

#### For customers who use DTS technology:

"Supply of this implementation of DTS technology does not convey a license, exhaust DTS' rights in the implementation, or imply a right under any patent, or any other industrial or intellectual property right of DTS to use, offer for sale, sell, or import such implementation in any finished end-user or ready-to-use final product. Notice is hereby provided that a license from DTS is required prior to such use."

"This product made under license to U.S. Patents 5,451,942; 5,956,674; 5,974,380; 5,978,762; 6,487,535; 6,226,616 and/or foreign counterparts."

"© 1996 - 2010 DTS, Inc."

## **Revision History**

| Date       | Version | Description     |
|------------|---------|-----------------|
| 2010-12-15 | 1.00    | Initial release |

#### **TABLE OF CONTENTS**

#### **Contents**

| Revi | sion History                     | 3 |
|------|----------------------------------|---|
|      | LE OF CONTENTS                   |   |
|      | Contents                         |   |
|      | Introduction                     |   |
|      | How to select DRAM               |   |
|      | How to select DRAM on bootloader |   |
|      | How to select DRAM on kernel     |   |
| 3.   | How to change DRAM Configuration | 7 |
|      | Setting in case of DDR2 SDRAM    |   |
| 3.2. | Setting in case of DDR3 SDRAM    | 🤅 |
|      | Example                          |   |

#### 1. Introduction

This document explains DRAM Configuration of Telechips Android platform.

The user can select couple of types of DRAM verified on the Telechips evaluation board and this document explains how to change the setting values.

The followings are DRAMs which can be selected in the SDK.

| DDR2 SDRAM | HXB18T2G160AF<br>HY5PS1G1631CFPS6<br>HY5PS1G831CFPS6 |
|------------|------------------------------------------------------|
| DDR3 SDRAM | K4B2G1646C HCK0<br>K4B1G1646E HCH9                   |

#### 2. How to select DRAM

The following is how to select DRAM which has been already added in the Android SDK. DRAM which can be selected in the SDK is a device tested on the Telechips emulation board.

In the Android SDK, DRAM setting is done in two, the bootloader and kernel.

#### 2.1. How to select DRAM on bootloader

In order to select DRAM in the bootlander, "bootable\bootloader\k\target\tcc8800 evm\rules.mk" should be changed as below.

#### DRAM Type

```
#TCC_MEM_TYPE := DRAM_DDR2
TCC_MEM_TYPE := DRAM_DDR3 <<- selected
```

#### DRAM Size

```
#TCC_MEM_SIZE := 256
TCC_MEM_SIZE := 512 <<- selected
```

#### DRAM Product

```
#DEFINES += CONFIG_DDR2_HXB18T2G160AF
#DEFINES += CONFIG_DDR2_HY5PS1G1631CFPS6
#DEFINES += CONFIG_DDR2_HY5PS1G831CFPS6
DEFINES += CONFIG_DDR3_K4B2G1646C_HCK0
                                       <<- selected
```

#### 2.2. How to select DRAM on kernel

In order to select DRAM in the kernel, move to "kernel\" and execute make menuconfig.

Enter into the system type of Memuconfig in order to select DRAM Type, Size, and Product.

```
Arrow keys navigate the menu. <Enter> selects submenus --->. Highlighted letters are
\texttt{hotkeys.} \quad \texttt{Pressing} \,\, \footnotesize \texttt{<Y>} \,\, \texttt{includes,} \,\, \footnotesize \footnotesize \footnotesize \texttt{<N>} \,\, \texttt{excludes,} \,\, \footnotesize \texttt{M>} \,\, \texttt{modularizes} \,\, \texttt{features.} \quad \texttt{Press}
<Esc><Esc> to exit, <?> for Help, </> for Search. Legend: [*] built-in [ ] excluded
<M>> module < > module capable
             [*] MMU-based Paged Memory Management Support
                     RM system type (Telechips TCC-based)
                    TCC Processor Family (TCC88xx) --->
                    *** DRAM Settings ***
                    DRAM Memory Size (512MB) --->
                     DR3 settings (Samsung K4B2G1646C-HCKO) --->
```

#### 3. How to change DRAM Configuration

This explains how to change the timing parameter of the selected DRAM.

Both the bootloader and kernel should be changed in the following locations.

| Bootloader | bootable\bootloader\lk\target\tcc8800_evm\include\tcc_ddr.h |
|------------|-------------------------------------------------------------|
| kernel     | kernel\arch\arm\mach-tcc88xx\include\mach\tcc_ddr.h         |

These two files are the same. However, since bootloader and kernel are separately built, these files are located in the separate places.

#### 3.1. Setting in case of DDR2 SDRAM

In the setting in DDR2 SDRAM, the configuration and access timing parameters of the DRAM can be changed by changing the defined values of **CONFIG DRAM DDR2** feature in tcc\_ddr.h.

The followings are DRAM configuration related defines.

- DDR2\_PHYSICAL\_CHIP\_NUM
  - : The number of physical DRAM chips
- DDR2 LOGICAL CHIP NUM
  - : The number of logical DRAM chips

If two DRAM chips whose data bit is 16 bit are connected to 32Bit Data Bus of the TCC Memory Controller, the number of logical DRAM is one.

- DDR2\_MAX\_SPEED
  - : It is available max clock speed. In the case of DDR2\_800, the clock can be set to 400MHz.
- DDR2\_CL
  - : CAS Latency
- DDR2 PAGE SIZE
  - : Page size
- DDR2 BURST LEN
  - : Burst length
- DDR2\_READ\_BURST\_TYPE
  - : Read burst type
- DDR2\_EA\_MB\_SIZE
  - : The size of each chip (MByte unit)
- DDR2\_TOTAL\_MB\_SIZE
  - : Total size of entire chip (MByte unit)
- DDR2 ROWBITS
  - : The number of row address bits
- DDR2 COLBITS
  - : The number of column address bits
- DDR2 BANK BITS
  - : The number of bank address bits
- DDR2\_BANK\_NUM
  - : The number of banks
- DDR2\_PHYSICAL\_DATA\_BITS
  - : The number of physical data bits
- DDR2 LOGICAL DATA BITS
  - : The number of logical data bits

If two DRAM chips whose data bit is 16 bit are connected to 32Bit Data Bus of the TCC Memory Controller, the number of logical data bit is 32.



# TCCXXXX TCCxxxx-Android-ALL-V1.00E-DRAM Configuration Guide

**SETTING IN CASE OF DDR2 SDRAM** 

The followings are DRAM access timing parameter related defines.

- DDR2\_tRFC\_ps
  - : The auto-refresh command time (pico sec unit)
- DDR2 tREFI ps
  - : Average periodic refresh interval (pico sec unit)
- DDR2 tRRD ps
  - : Active bank x to Active bank y delay (pico sec unit)
- DDR2\_tRRD\_ck
  - : Minimum required clock for tRRD (nCK unit)
- DDR2\_tRAS\_ps
  - : RAS to pre-charge delay (pico sec unit)
- DDR2\_tRAS\_ck
  - : Minimum required clock for tRAS (nCK unit)
- DDR2 tRC ps
  - : Active bank x to Active bank x delay (pico sec unit)
- DDR2\_tRC\_ck
  - : Minimum required clock for tRC (nCK unit)
- DDR2 tRCD ps
  - : RAS to CAS minimum delay (pico sec unit)
- DDR2 tRCD ck
  - : Minimum required clock for tRCD (nCK unit)
- DDR2\_tRP\_ps
  - : Pre-charge to RAS delay (pico sec unit)
- DDR2 tRP ck
  - : Minimum required clock for tRP (nCK unit)
- DDR2 tWTR ps
  - : Write to read delay (pico sec unit)
- DDR2\_tWTR\_ck
  - : Minimum required clock for tWTR (nCK unit)
- DDR2\_tWR\_ps
  - : Write to pre-charge delay (pico sec unit)
- DDR2 tWR ck
  - : Minimum required clock for tWR (nCK unit)
- DDR2\_tRTP\_ps
  - : Read to pre-charge delay (pico sec unit)
- DDR2\_tRTP\_ck
  - : Minimum required clock for tRTP (nCK unit)
- DDR2 tFAW ps
  - : Four bank activate time (pico sec unit)
- DDR2\_tFAW\_ck
  - : Minimum required clock for tFAW (nCK unit)
- DDR2 tXSR ck
  - : Self refresh exit power down to next valid command delay (nCK unit)
- DDR2 tXP ck
  - : Exit power down to next valid command delay (nCK unit)
- DDR2\_tCKE\_ck
  - : CKE minimum pulse width (nCK unit)
- DDR2 tMRD ck
  - : Mode register set command period (nCK unit)

TeleChips

#### 3.2. Setting in case of DDR3 SDRAM

In the setting in DDR3 SDRAM, the configuration and access timing parameters of the DRAM can be changed by changing the defined values of **CONFIG DRAM DDR3** feature in tcc\_ddr.h.

The followings are DRAM configuration related defines.

- DDR3 PHYSICAL CHIP NUM
  - : The number of physical DRAM chips
- DDR3 LOGICAL CHIP NUM
  - : The number of logical DRAM chips

If two DRAM chips whose data bit is 16 bit are connected to 32Bit Data Bus of the TCC Memory Controller, the number of logical DRAM is one.

- DDR3\_MAX\_SPEED
  - : It is available max clock speed.
- DDR3 CL
  - : CAS Latency
- DDR3 AL
  - : Additive Latency
- DDR3\_PAGE\_SIZE
  - : Page size
- DDR3 BURST LEN
  - : Burst length
- DDR3\_READ\_BURST\_TYPE
  - : Read burst type
- DDR3\_EA\_MB\_SIZE
  - : The size of each chip (MByte unit)
- DDR3 TOTAL MB SIZE
  - : Total size of entire chip (MByte unit)
- DDR3\_ROWBITS
  - : The number of row address bits
- DDR3 COLBITS
  - : The number of column address bits
- DDR3 BANK NUM
  - : The number of banks

The followings are DRAM access timing parameter related defines.

- DDR3 tRFC ps
  - : The auto-refresh command time (pico sec unit)
- DDR3\_tREFI\_ps
  - : Average periodic refresh interval (pico sec unit)
- DDR3\_tRCD\_ps
  - : RAS to CAS minimum delay (pico sec unit)
- DDR3\_tRCD\_ck
  - : Minimum required clock for tRCD (nCK unit)
- DDR3\_tRP\_ps
  - : Pre-charge to RAS delay (pico sec unit)
- DDR3 tRP ck
  - : Minimum required clock for tRP (nCK unit)
- DDR3\_tRC\_ps
  - : Active bank x to Active bank x delay (pico sec unit)
- DDR3\_tRC\_ck
  - : Minimum required clock for tRC (nCK unit)
- DDR3 tRAS ps
  - : RAS to pre-charge delay (pico sec unit)
- DDR3\_tRAS\_ck

## TCCXXXX TCCxxxx-Android-ALL-V1.00E-DRAM Configuration Guide

**SETTING IN CASE OF DDR3 SDRAM** 

- : Minimum required clock for tRAS (nCK unit)
- DDR3 tRTP ps
  - : Read to pre-charge delay (pico sec unit)
- DDR3\_tRTP\_ck
  - : Minimum required clock for tRTP (nCK unit)
- DDR3\_tWTR\_ps
  - : Write to read delay (pico sec unit)
- DDR3 tWTR ck
  - : Minimum required clock for tWTR (nCK unit)
- DDR3\_tWR\_ps
  - : Write to pre-charge delay (pico sec unit)
- DDR3\_tWR\_ck
  - : Minimum required clock for tWR (nCK unit)
- DDR3\_tRRD\_ps
  - : Active bank x to Active bank y delay (pico sec unit)
- DDR3 tRRD ck
  - : Minimum required clock for tRRD (nCK unit)
- DDR3\_tFAW\_ps
  - : Four bank activate time (pico sec unit)
- DDR3 tFAW ck
  - : Minimum required clock for tFAW (nCK unit)
- DDR3 tXS ps
  - : Exit self-refresh to command not requiring a locked DLL (pico sec unit)
- DDR3\_tXS\_ck
  - : Minimum required clock for tXS (nCK unit)
- DDR3\_tXP\_ps
  - : DLL on, any valid command, or DLL off to commands not requiring locked DLL (pico sec unit)
- DDR3\_tXP\_ck
  - : Minimum required clock for tXP (nCK unit)
- DDR3\_tCKE\_ps
  - : CKE minimum pulse width (pico sec unit)
- DDR3\_tCKE\_ck
  - : Minimum required clock for tCKE (nCK unit)
- DDR3 tMRD ck
  - : Mode register set command period (nCK unit)

#### 4. Example

This is the example of Hynix DDR2 SDRAM HY5PS1G1631CFPS6 Memory setting with the above defines.

In the case of this memory, physically two chips are used. However, logically it is like one chip is used with the below H/W configuration.



TeleChips

The followings are the setting values with the above H/W configuration.

```
/*_____
DDR2 Configuation
#define DDR2_PHYGICAL_CHIP_NUM 2
#define DDR2_LOGICAL_CHIP_NUM 1
#define DDR2_MAX_SPEED DDR2_800
#define DDR2_CL 6
#define DDR2_CL 6
#define DDR2_PAGE_SIZE PAGE_2KB
#define DDR2_BURST_LEN BL_4
#define DDR2_READ_BURST_TYPE RBT_SEQUENTIAL
#define DDR2_EA_MB_SIZE 128
#define DDR2_EA_MB_SIZE 128
#define DDR2_TOTAL_MB_SIZE (DDR2_EA_MB_SIZE * DDR2_PHYGICAL_CHIP_NUM)
#define DDR2_ROWBITS
                              13
#define DDR2_COLBITS
                                          10
                                          3
#define DDR2_BANK_BITS
#define DDR2_BANK_NUM
#define DDR2_PHGICAL_DATA_BITS 16
#define DDR2_LOGICAL_DATA_BITS 32
DDR2 Access Timing Parameters
                               127500
7800000
#define DDR2_tRFC_ps
#define DDR2_tREFI_ps
#define DDR2_tRRD_ps
                                      10000
#define DDR2_tRRD_ck
                                          1
#define DDR2_tRAS_ps
                                       45000
#define DDR2_tRAS_ck
                                          7
#define DDR2_tRC_ps
                                        60000
#define DDR2_tRC_ck
                                          7
#define DDR2_tRCD_ps
                                        15000
#define DDR2_tRCD_ck
#define DDR2_tRP_ps
                                        15000
#define DDR2_tRP_ck
                                           1
#define DDR2_tWTR_ps
                                        7500
#define DDR2 tWTR ck
                                           2
#define DDR2 tWR ps
                                        15000
#define DDR2 tWR ck
                                           1
                                         7500
#define DDR2 tRTP ps
#define DDR2 tRTP ck
                                           2
#define DDR2_tFAW_ps
                                         45000
#define DDR2_tFAW_ck
                                           1
#define DDR2_tXSR_ck
                                          200
#define DDR2_tXP_ck
                                           2
#define DDR2_tCKE_ck
                                            3
#define DDR2_tMRD_ck
                                            2
```